草庐IT

Java 套接字和 TCP 调整

全部标签

java - 表示包安装和系统依赖关系的最佳数据结构

我正在尝试根据面试过程创建一个程序(我选择Java,但可以是C/C++或GoLang)来表示/模拟Linux/Unix环境中存在的包安装和系统依赖项。基本上,我会执行以下要求:1)维护已安装包及其依赖项的记录。2)支持响应命令显式安装包(除非已经安装)。3)如果需要安装另一个包,支持隐式安装一个包。4)支持显式删除一个包以响应命令(如果不需要支持其他包)。5)如果不再需要支持另一个组件,则支持隐式删除包。在安装包之前,自动安装它需要的所有包。在删除包之前,请确认没有其他包需要它。在删除包之前,必须手动删除依赖包。我想要最好的数据结构(以及我可以检查的链接)的提示,我可以用它来做到这一点

go - Golang在TCP上死锁。一段时间后写入

我有这个测试代码。一段时间后,所有gorutines都会锁定carbonwritebuf.flush()而不会出现任何错误。停下来。线程越多,间隔越短,停止越快。如果我杀死接收到的应用程序(NC-L127.0.0.12002-K-M1000),Golang会重置连接并再次工作。但是,如果gorutine已经停止,那么就没有重启和任何消息。packagemainimport("bufio""flag""fmt""net""time")var(SERVERstringINTERVALintTHREADSint)funcmain(){flag.StringVar(&SERVER,"s","l

Golang 同时从一个 tcp 连接读取

我在使用Go项目时遇到了一些问题。代码太大,无法复制和粘贴,所以我会尽力解释。我的程序首先连接到TCP服务器,然后启动一个goroutine,将连接对象作为参数传递。我想要实现的是让客户端从tcp连接中无限读取,同时获取用户输入并通过发送检索数据与服务器通信。我试过使用另一个goroutine,但程序会在尝试从服务器检索数据时阻塞。这是goplayground上错误的重现。https://play.golang.org/p/OD5ozCRmy_4服务器https://play.golang.org/p/t1r_BAQM-jn客户基本上,每当客户端尝试从连接中读取数据时,它就会卡住。感谢

node.js - 如果 TCP 服务器(nodejs)发送没有分隔符的数据,TCP 客户端(golang)如何知道数据何时结束 "\n"

我的问题:我正在尝试读取TCP服务器(nodejs)发送的数据但我不能,服务器发送数据时没有分隔线“\r\n”或“\n”我是Golang的新手,但我一直在尝试很多方法来获取服务器发送的所有数据。来自Server.js的代码,这是一个简单的示例varnet=require('net');varserver=net.createServer(function(socket){console.log("NewClient")socket.on('data',function(data){console.log("data",data,data.toString())socket.write(

go - TCP 连接似乎一次读取了太多字节

我正在用Go编写一个FTP服务器,但在列出文件/目录时遇到了问题。似乎正在发生的事情是服务器正在分别且正确地发送文件,但是当从连接中读取它们时,它们一次被读取多个。我已经尝试更改缓冲区大小以及在发送每个文件名之前发送确认,但是当从连接读取时它最终读取的字节数比预期的多。这是来自服务器的相关部分:for_,fn:=rangefiles{conn.Write([]byte(fn.Name()))}上面代码中,files是[]os.FileInfo从ioutil.ReadDir("./")获取文件在当前目录中。测试时,它会发送正确的文件名以及每个名称的正确字节。在客户端我有这个:varbuf

linux - http: 接受错误:接受 tcp [::]:8080: accept4: 打开的文件太多;

我已经用Golang编写了RESTAPI,并且正在使用Jmeter对我的API进行性能测试。当我对300个或更多用户运行测试时,每个用户发送20个请求,每个请求之间的间隔为500毫秒,我收到以下错误:http:Accepterror:accepttcp[::]:8080:accept4:toomanyopenfiles;我在AWSEC2服务器上运行这个Go应用程序。我在8GBRAM机器上运行这个应用程序。以下是我已经尝试过的:我已将ulimit增加到一个足够好的数字。当我运行ulimit-n命令时,输出为:1048576在我的代码中,我确保响应主体已关闭。但是,这些都没有解决问题。任何

go - gRPC 实现性能 - java v/s goLang

gRPC支持多种语言的rpc服务端和客户端实现。我需要知道在goLangv/sJava中实现gRPC服务器和客户端是否有任何显着的性能差异。如果我们正在寻找高性能和可扩展性,go还是java哪个实现更好谢谢吉里什TS 最佳答案 看看publicgrpcbenchmarks.multi-languageperformancedashboard@master显示Go和Java并驾齐驱。一般来说,Java的性能和延迟稍好一些,但Go在某些情况下表现更好,例如流式乒乓的延迟。由于它们非常相似,因此最好根据其他因素来决定您要使用哪种语言。

java - Go、Java 和 C# 中数组的最大长度是多少?

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭8年前。Improvethisquestion我可以在Go、Java和C#中声明的数组的最大长度是多少?它与运行时的最大内存有关吗?或者他们有标准吗?

PHP/Go 套接字通信

我正在尝试使用套接字在Go和PHP之间进行通信。我使用的代码是:开始:fmt.Println("Launchingserver...")ln,_:=net.Listen("tcp",":8080")conn,_:=ln.Accept()for{message,_:=bufio.NewReader(conn).ReadString('\n')fmt.Print("MessageReceived:",string(message))conn.Write([]byte("test"+"\n"))}PHP:$address=gethostbyaddr($ip);$socket=socket_c

linux - 从 TCP 连接获取 HTTP header

我正在用golang为Linux编写类似应用程序的代理程序。该应用程序在执行时将监听所有TCP连接并将它们重定向到代理服务器地址。在应用程序之间还向HTTPheader添加了“Proxy-Authorisation:Basic...”header。当我看到TCPheader时,我无法获得HTTPheader。我哪里出错了或如何提取HTTP数据?还有其他方法可以实现吗? 最佳答案 我也是golang的新手,但就从tcp套接字获取HTTP数据而言,下面的代码对我有用。packagemainimport"net"import"fmt"im